<template>
  <div>
    <div>
      <div style="display: flex; justify-content: space-between">
        <div>
          <el-input v-model="empName" clearable placeholder="请输入员工名进行搜索"
                    @keydown.enter.native="initEmps" @clear="initEmps"
                    prefix-icon="el-icon-search" style="width: 300px;margin-right: 10px"
                    :disabled="showAdvanceSearchVisible"/>
          <el-button type="primary" icon="el-icon-search" @click="initEmps" :disabled="showAdvanceSearchVisible">搜索</el-button>
          <el-button type="primary" @click="showAdvanceSearchVisible = !showAdvanceSearchVisible">
            <i :class="showAdvanceSearchVisible?'fa fa-angle-double-up':'fa fa-angle-double-down'" aria-hidden="true"></i>
            高级搜索
          </el-button>
        </div>
        <div>
          <el-upload action="/employee/basic/import"
                     :headers="header"
                     style="display: inline-flex; margin-right: 8px;"
                     :show-file-list="false"
                     :on-success="onSuccess"
                     :on-error="onError"
                     :disabled="importEmpsDisabled"
                     :before-upload="beforeUpload">
            <el-button type="success" :icon="importEmpsBtnIcon" :disabled="importEmpsDisabled">
              {{importEmpsBtnText}}
            </el-button>
          </el-upload>
          <el-button type="success" @click="exportData" icon="el-icon-download">
            导出数据
          </el-button>
          <el-button type="primary" icon="el-icon-plus" @click="showAddEmpView">添加员工</el-button>
        </div>
      </div>
    </div>
    <transition name="slide-fade">
      <div v-show="showAdvanceSearchVisible" style="border: 1px solid #409eff; border-radius: 5px; box-sizing: border-box;padding: 5px;margin: 10px 0px;">
        <el-row>
          <el-col :span="5">
            政治面貌
            <el-select v-model="searchValue.politicId" placeholder="政治面貌" size="mini" style="width: 130px;">
              <el-option
                  v-for="item in politicsStatus"
                  :key="item.id"
                  :label="item.name"
                  :value="item.id">
              </el-option>
            </el-select>
          </el-col>
          <el-col :span="4">
            民族
            <el-select v-model="searchValue.nationId" placeholder="民族" size="mini" style="width: 130px;">
              <el-option
                  v-for="nation in nations"
                  :key="nation.id"
                  :label="nation.name"
                  :value="nation.id">
              </el-option>
            </el-select>
          </el-col>
          <el-col :span="4">
            职位
            <el-select v-model="searchValue.posId" placeholder="职位" size="mini" style="width: 130px;">
              <el-option
                  v-for="position in positions"
                  :key="position.id"
                  :label="position.name"
                  :value="position.id">
              </el-option>
            </el-select>
          </el-col>
          <el-col :span="4">
            职称
            <el-select v-model="searchValue.jobLevelId" placeholder="职称" size="mini" style="width: 130px;">
              <el-option
                  v-for="joblevel in joblevels"
                  :key="joblevel.id"
                  :label="joblevel.name"
                  :value="joblevel.id">
              </el-option>
            </el-select>
          </el-col>
          <el-col :span="7">
            聘用形式
            <el-radio-group v-model="searchValue.engageForm">
              <el-radio label="劳动合同">劳动合同</el-radio>
              <el-radio label="劳务合同">劳务合同</el-radio>
            </el-radio-group>
          </el-col>
        </el-row>
        <el-row style="margin-top: 10px">
          <el-col :span="5">
            所属部门
            <el-popover
                placement="bottom"
                title="请选择部门"
                width="250"
                trigger="manual"
                v-model="searchVisible">
              <el-tree :data="allDeps" :props="defaultProps"
                       @node-click="searchHandleNodeClick" default-expand-all></el-tree>
              <div slot="reference"
                   style="width: 130px;display: inline-flex; border: 1px solid #dedede;
                        height: 24px; border-radius: 5px;cursor: pointer; align-items: center;
                        font-size: 13px; padding-left: 8px; box-sizing: border-box"
                   @click="showSearchDepView">{{searchInputDepName}}</div>
            </el-popover>
          </el-col>
          <el-col :span="10">
            入职日期
            <el-date-picker
                v-model="searchValue.beginDateScope"
                value-format="yyyy-MM-dd"
                type="daterange"
                unlink-panels
                size="mini"
                range-separator="至"
                start-placeholder="开始日期"
                end-placeholder="结束日期">
            </el-date-picker>
          </el-col>
          <el-col :span="4" :offset="5">
            <el-button size="mini">取消</el-button>
            <el-button type="primary" icon="el-icon-search" size="mini" @click="initEmps">搜索</el-button>
          </el-col>
        </el-row>
      </div>
    </transition>
    <div style="margin-top: 20px;">
      <el-table
          :data="emps"
          border
          stripe
          style="width: 100%"
          v-loading="loading"
          element-loading-text="拼命加载中"
          element-loading-spinner="el-icon-loading"
          element-loading-background="rgba(0, 0, 0, 0.8)"
          @selection-change="">
        <el-table-column
            type="selection"
            width="55">
        </el-table-column>
        <el-table-column
            prop="name"
            label="姓名"
            align="left"
            fixed
            width="90">
        </el-table-column>
        <el-table-column
            prop="workId"
            label="工号"
            align="left"
            width="85">
        </el-table-column>
        <el-table-column
            prop="gender"
            label="性别"
            align="left"
            width="50">
        </el-table-column>
        <el-table-column
            prop="birthday"
            label="出生日期"
            align="left"
            width="95">
        </el-table-column>
        <el-table-column
            prop="idCard"
            label="身份证号"
            align="left"
            width="150">
        </el-table-column>
        <el-table-column
            prop="wedlock"
            label="婚姻状况"
            align="left"
            width="70">
        </el-table-column>
        <el-table-column
            prop="nation.name"
            label="民族"
            align="left"
            width="50">
        </el-table-column>
        <el-table-column
            prop="nativePlace"
            label="籍贯"
            align="left"
            width="100">
        </el-table-column>
        <el-table-column
            prop="politicsStatus.name"
            label="政治面貌"
            align="left"
            width="120">
        </el-table-column>
        <el-table-column
            prop="email"
            label="邮箱"
            align="left"
            width="220">
        </el-table-column>
        <el-table-column
            prop="phone"
            label="电话号码"
            align="left"
            width="100">
        </el-table-column>
        <el-table-column
            prop="address"
            label="联系地址"
            align="left"
            width="300">
        </el-table-column>
        <el-table-column
            prop="department.name"
            label="所属部门"
            align="left"
            width="100">
        </el-table-column>
        <el-table-column
            prop="joblevel.name"
            label="职称"
            align="left"
            width="100">
        </el-table-column>
        <el-table-column
            prop="position.name"
            label="职位"
            align="left"
            width="100">
        </el-table-column>
        <el-table-column
            prop="engageForm"
            label="聘用形式"
            align="left"
            width="85">
        </el-table-column>
        <el-table-column
            prop="tiptopDegree"
            label="最高学历"
            align="left"
            width="80">
        </el-table-column>
        <el-table-column
            prop="school"
            label="毕业院校"
            align="left"
            width="150">
        </el-table-column>
        <el-table-column
            prop="specialty"
            label="专业"
            align="left"
            width="150">
        </el-table-column>
        <el-table-column
            prop="workState"
            label="在职状态"
            align="left"
            width="70">
        </el-table-column>
        <el-table-column
            prop="beginDate"
            label="入职日期"
            align="left"
            width="95">
        </el-table-column>
        <el-table-column
            prop="conversionTime"
            label="转正日期"
            align="left"
            width="95">
        </el-table-column>
        <el-table-column
            prop="beginContract"
            label="合同起始日期"
            align="left"
            width="95">
        </el-table-column>
        <el-table-column
            prop="endContract"
            label="合同截止日期"
            align="left"
            width="95">
        </el-table-column>
        <el-table-column
            label="合同期限"
            align="left"
            width="100">
          <template slot-scope="scope">
            <el-tag>{{scope.row.contractTerm}}</el-tag>年
          </template>
        </el-table-column>
        <el-table-column
            label="操作"
            fixed="right"
            width="270">
          <template slot-scope="scope">
            <el-button size="mini" @click="showEditEmpView(scope.row)">编辑</el-button>
            <el-button size="mini" type="primary">查看高级资料</el-button>
            <el-button size="mini" type="danger" @click="deleteEmp(scope.row)">删除</el-button>
          </template>
        </el-table-column>
      </el-table>
      <div style="display: flex;justify-content: flex-end">
        <el-pagination
            background
            layout="prev, pager, next, jumper, ->, total,sizes"
            :total="total"
            @size-change="sizeChange"
            @current-change="currentChange">
        </el-pagination>
      </div>
    </div>
    <el-dialog
        :title="title"
        :visible.sync="dialogVisible"
        width="80%">
      <div>
        <el-form ref="empForm" :model="emp" :rules="rules">
          <el-row>
            <el-col :span="6">
              <el-form-item label="姓名：" prop="name">
                <el-input size="mini" prefix-icon="el-icon-edit"
                          style="width: 150px;" v-model="emp.name"
                          placeholder="请输入姓名"/>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="性别：" prop="gender">
                <el-radio-group v-model="emp.gender">
                  <el-radio label="男">男</el-radio>
                  <el-radio label="女">女</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="出生日期：" prop="birthday">
                <el-date-picker
                    v-model="emp.birthday"
                    type="date"
                    value-format="yyyy-MM-dd"
                    size="mini"
                    style="width: 150px;"
                    placeholder="出生日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="政治面貌：" prop="politicId">
                <el-select v-model="emp.politicId" placeholder="政治面貌" size="mini" style="width: 200px;">
                  <el-option
                      v-for="item in politicsStatus"
                      :key="item.id"
                      :label="item.name"
                      :value="item.id">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item label="民族：" prop="nationId">
                <el-select v-model="emp.nationId" placeholder="民族" size="mini" style="width: 150px;">
                  <el-option
                      v-for="nation in nations"
                      :key="nation.id"
                      :label="nation.name"
                      :value="nation.id">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="籍贯：" prop="nativePlace">
                <el-input v-model="emp.nativePlace" placeholder="请输入籍贯"
                          prefix-icon="el-icon-edit" size="mini"
                          style="width: 120px;"/>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="电子邮箱：" prop="email">
                <el-input v-model="emp.email" placeholder="请输入邮箱" size="mini" style="width: 150px;" prefix-icon="el-icon-message"/>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="联系地址：" prop="address">
                <el-input v-model="emp.address" placeholder="请输入联系地址" size="mini" style="width: 200px;" prefix-icon="el-icon-edit"/>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item label="职位：" prop="posId">
                <el-select v-model="emp.posId" placeholder="职位" size="mini" style="width: 150px;">
                  <el-option
                      v-for="position in positions"
                      :key="position.id"
                      :label="position.name"
                      :value="position.id">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="职称：" prop="jobLevelId">
                <el-select v-model="emp.jobLevelId" placeholder="职称" size="mini" style="width: 120px;">
                  <el-option
                      v-for="joblevel in joblevels"
                      :key="joblevel.id"
                      :label="joblevel.name"
                      :value="joblevel.id">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="所属部门：" prop="departmentId">
                <el-popover
                    placement="bottom"
                    title="请选择部门"
                    width="250"
                    trigger="manual"
                    v-model="visible">
                  <el-tree :data="allDeps" :props="defaultProps"
                           @node-click="handleNodeClick" default-expand-all></el-tree>
                  <div slot="reference"
                       style="width: 150px;display: inline-flex; border: 1px solid #dedede;
                        height: 24px; border-radius: 5px;cursor: pointer; align-items: center;
                        font-size: 13px; padding-left: 8px; box-sizing: border-box"
                       @click="showDepView">{{inputDepName}}</div>
                </el-popover>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="电话号码：" prop="phone">
                <el-input v-model="emp.phone" placeholder="请输入电话号码" prefix-icon="el-icon-phone" size="mini" style="width: 200px;"/>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item label="工号：" prop="workID">
                <el-input v-model="emp.workId" disabled placeholder="请输入工号" prefix-icon="el-icon-edit" size="mini" style="width: 150px;"/>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="学历：" prop="tiptopDegree">
                <el-select v-model="emp.tiptopDegree" placeholder="学历" size="mini" style="width: 120px;">
                  <el-option
                      v-for="(tiptopDegree,index) in tiptopDegrees"
                      :key="index"
                      :label="tiptopDegree"
                      :value="tiptopDegree">
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="毕业院校：" prop="school">
                <el-input v-model="emp.school" placeholder="请输入毕业院校" prefix-icon="el-icon-edit" size="mini" style="width: 150px;"/>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="专业名称：" prop="specialty">
                <el-input v-model="emp.specialty" placeholder="请输入专业名称" prefix-icon="el-icon-edit" size="mini" style="width: 200px;"/>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item label="入职日期：" prop="beginDate">
                <el-date-picker
                    v-model="emp.beginDate"
                    type="date"
                    value-format="yyyy-MM-dd"
                    size="mini"
                    style="width: 123px;"
                    placeholder="入职日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="转正日期：" prop="conversionTime">
                <el-date-picker
                    v-model="emp.conversionTime"
                    type="date"
                    value-format="yyyy-MM-dd"
                    size="mini"
                    style="width: 100px;"
                    placeholder="转正日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="合同起始日期：" prop="beginContract">
                <el-date-picker
                    v-model="emp.beginContract"
                    type="date"
                    value-format="yyyy-MM-dd"
                    size="mini"
                    style="width: 123px;"
                    placeholder="合同起始日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="合同截止日期：" prop="endContract">
                <el-date-picker
                    v-model="emp.endContract"
                    type="date"
                    value-format="yyyy-MM-dd"
                    size="mini"
                    style="width: 170px;"
                    placeholder="合同截止日期">
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="8">
              <el-form-item label="身份证号码：" prop="idCard">
                <el-input v-model="emp.idCard" placeholder="请输入身份证号码"
                          prefix-icon="el-icon-edit" size="mini" style="width: 180px;"/>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="聘用形式：" prop="engageForm">
                <el-radio-group v-model="emp.engageForm">
                  <el-radio label="劳动合同">劳动合同</el-radio>
                  <el-radio label="劳务合同">劳务合同</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="婚姻状况：" prop="wedlock">
                <el-radio-group v-model="emp.wedlock">
                  <el-radio label="已婚">已婚</el-radio>
                  <el-radio label="未婚">未婚</el-radio>
                  <el-radio label="离异">离异</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
          </el-row>
        </el-form>
      </div>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">取 消</el-button>
        <el-button type="primary" @click="EmpOperate">确 定</el-button>
      </span>
    </el-dialog>
  </div>
</template>

<script>
export default {
  name: "EmpBasic",
  data(){
    return{
      searchVisible:false,
      searchValue:{
        politicId: null,
        nationId: null,
        posId: null,
        jobLevelId: null,
        engageForm: '',
        departmentId: null,
        beginDateScope:null
      },
      showAdvanceSearchVisible:false,
      header:{
        Authorization:window.sessionStorage.getItem('tokenStr')
      },
      importEmpsDisabled:false,
      importEmpsBtnText:'导入数据',
      importEmpsBtnIcon:'el-icon-upload2',
      empName:'',
      emps:[],
      loading:false,
      total:0,
      currentPage:1,
      size:10,
      dialogVisible:false,
      emp:{
        id: '',
        name: '',
        gender: '',
        birthday: '',
        idCard: '',
        wedlock: '',
        nationId: null,
        nativePlace: '',
        politicId: null,
        email: '',
        phone: '',
        address: '',
        departmentId: null,
        jobLevelId: null,
        posId: null,
        engageForm: '',
        tiptopDegree: '',
        specialty: '',
        school: '',
        beginDate: '',
        workState: '在职',
        workId: '',
        contractTerm: null,
        conversionTime: '',
        notWorkDate: null,
        beginContract: '',
        endContract: '',
        workAge: null,
        salaryId: null,
      },
      nations:[],
      joblevels:[],
      politicsStatus:[],
      positions:[],
      tiptopDegrees: ['博士', '硕士', '本科', '大专', '高中', '初中', '小学', '其他'],
      visible:false,
      defaultProps: {
        children: 'children',
        label: 'name'
      },
      allDeps:[],
      title:'',
      inputDepName:'',
      searchInputDepName:'',
      rules:{
        name: [{required:true, message:'请输入员工名', trigger:'blur'}],
        gender: [{required:true, message:'请输入员工性别', trigger:'blur'}],
        birthday: [{required:true, message:'请输入出生日期', trigger:'blur'}],
        idCard: [{required:true, message:'请输入身份证号', trigger:'blur'},
                 {pattern:/(^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$)|(^[1-9]\d{5}\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{2}$)/,
                   message:'身份证号码格式有误', trigger:'blur'}],
        wedlock: [{required:true, message:'请输入婚姻状况', trigger:'blur'}],
        nationId: [{required:true, message:'请输入民族', trigger:'blur'}],
        nativePlace: [{required:true, message:'请输入籍贯', trigger:'blur'}],
        politicId: [{required:true, message:'请输入政治面貌', trigger:'blur'}],
        email: [{required:true, message:'请输入邮箱', trigger:'blur'},
                {type:'email', message:'邮箱地址格式错误', trigger:'blur'}],
        phone: [{required:true, message:'请输入电话号码', trigger:'blur'}],
        address: [{required:true, message:'请输入员工地址', trigger:'blur'}],
        departmentId: [{required:true, message:'请输入部门', trigger:'blur'}],
        jobLevelId: [{required:true, message:'请输入职称', trigger:'blur'}],
        posId: [{required:true, message:'请输入职位', trigger:'blur'}],
        engageForm: [{required:true, message:'请输入聘用形式', trigger:'blur'}],
        tiptopDegree: [{required:true, message:'请输入学历', trigger:'blur'}],
        specialty: [{required:true, message:'请输入专业', trigger:'blur'}],
        school: [{required:true, message:'请输入毕业院校', trigger:'blur'}],
        beginDate: [{required:true, message:'请输入入职日期', trigger:'blur'}],
        workState: [{required:true, message:'请输入工作状态', trigger:'blur'}],
        workId: [{required:true, message:'请输入工号', trigger:'blur'}],
        contractTerm: [{required:true, message:'请输入合同期限', trigger:'blur'}],
        conversionTime: [{required:true, message:'请输入转正日期', trigger:'blur'}],
        notWorkDate: [{required:true, message:'请输入离职日期', trigger:'blur'}],
        beginContract: [{required:true, message:'请输入合同起始日期', trigger:'blur'}],
        endContract: [{required:true, message:'请输入合同结束日期', trigger:'blur'}],
        workAge: [{required:true, message:'请输入工龄', trigger:'blur'}],
      }
    }
  },
  methods:{
    onSuccess(){
      this.importEmpsBtnIcon = 'el-icon-upload2';
      this.importEmpsBtnText = '导入数据';
      this.importEmpsDisabled = false;
      this.initEmps();
    },
    onError(){
      this.importEmpsBtnIcon = 'el-icon-upload2';
      this.importEmpsBtnText = '导入数据';
      this.importEmpsDisabled = false;
    },
    beforeUpload(){
      this.importEmpsBtnIcon = 'el-icon-loading';
      this.importEmpsBtnText = '正在导入';
      this.importEmpsDisabled = true;
    },
    handleNodeClick(data){
      this.inputDepName = data.name;
      this.emp.departmentId = data.id;
      this.visible = !this.visible
    },
    searchHandleNodeClick(data){
      this.searchInputDepName = data.name;
      this.searchValue.departmentId = data.id;
      this.searchVisible = !this.searchVisible
    },
    getMaxWorkId(){
      this.getRequest('/employee/basic/maxWorkId').then(resp =>{
        if (resp){
          this.emp.workId = resp.obj;
        }
      })
    },
    initPositions() {
      this.getRequest('/employee/basic/positions').then(resp =>{
        if (resp){
          this.positions = resp;
        }
      })
    },
    initData(){
      if (!window.sessionStorage.getItem('nations')){
        this.getRequest('/employee/basic/nations').then(resp =>{
          if (resp){
            this.nations = resp;
            window.sessionStorage.setItem('nations',JSON.stringify(resp));
          }
        })
      }else {
        this.nations = JSON.parse(window.sessionStorage.getItem('nations'));
      }

      if (!window.sessionStorage.getItem('joblevels')){
        this.getRequest('/employee/basic/joblevels').then(resp =>{
          if (resp){
            this.joblevels = resp;
            window.sessionStorage.setItem('joblevels', JSON.stringify(resp));
          }
        })
      }else {
        this.joblevels = JSON.parse(window.sessionStorage.getItem('joblevels'));
      }

      if (!window.sessionStorage.getItem('politicsStatus')){
        this.getRequest('/employee/basic/politicsStatus').then(resp =>{
          if (resp){
            this.politicsStatus = resp;
            window.sessionStorage.setItem('politicsStatus',JSON.stringify(resp));
          }
        })
      }else {
        this.politicsStatus = JSON.parse(window.sessionStorage.getItem('politicsStatus'));
      }

      if (!window.sessionStorage.getItem('addDeps')){
        this.getRequest('/employee/basic/deps').then(resp =>{
          if (resp){
            this.allDeps = resp;
            window.sessionStorage.setItem('allDeps',JSON.stringify(resp));
          }
        })
      }else {
        this.allDeps = JSON.parse(window.sessionStorage.getItem('allDeps'))
      }

    },
    initEmps(){
      this.loading = true;
      let url = '/employee/basic/?currentPage='+this.currentPage +'&size='+this.size;
      if (this.showAdvanceSearchVisible){
        if (this.searchValue.politicId){
          url += '&politicId='+this.searchValue.politicId
        }
        if (this.searchValue.nationId){
          url += '&nationId='+this.searchValue.nationId
        }
        if (this.searchValue.posId){
          url += '&posId='+this.searchValue.posId
        }
        if (this.searchValue.departmentId){
          url += '&departmentId='+this.searchValue.departmentId
        }
        if (this.searchValue.engageForm){
          url += '&engageForm='+this.searchValue.engageForm
        }
        if (this.searchValue.jobLevelId){
          url += '&jobLevelId='+this.searchValue.jobLevelId
        }
        if (this.searchValue.beginDateScope){
          url += '&beginDateScope='+this.searchValue.beginDateScope
        }

        this.getRequest(url).then(resp =>{
          this.loading = false;
          if (resp){
            this.emps = resp.data;
            this.total = resp.total;
          }
        })

      } else {
        if (this.empName){
          url += '&empName='+this.empName
        }
        this.getRequest(url).then(resp =>{
          this.loading = false;
          if (resp){
            this.emps = resp.data;
            this.total = resp.total;
          }
        })
      }
    },
    currentChange(currentPage){
      console.log(currentPage)
      this.currentPage = currentPage;
      this.initEmps();
    },
    sizeChange(size){
      this.size = size;
      this.initEmps();
    },
    showAddEmpView(){
      this.title = '添加员工';
      this.emp = {
        id: null,
        name: '',
        gender: '',
        birthday: '',
        idCard: '',
        wedlock: '',
        nationId: null,
        nativePlace: '',
        politicId: null,
        email: '',
        phone: '',
        address: '',
        departmentId: null,
        jobLevelId: null,
        posId: null,
        engageForm: '',
        tiptopDegree: '',
        specialty: '',
        school: '',
        beginDate: '',
        workState: '在职',
        workId: '',
        contractTerm: null,
        conversionTime: '',
        notWorkDate: null,
        beginContract: '',
        endContract: '',
        workAge: null,
        salaryId: null,
      };
      this.inputDepName = '';
      this.getMaxWorkId();
      this.dialogVisible = true;
    },
    showDepView(){
      this.visible = !this.visible;
    },
    showSearchDepView(){
      this.searchVisible = !this.searchVisible;
    },
    EmpOperate(){
      this.$refs["empForm"].validate(valid =>{
        if (valid){
          if (!this.emp.id){
            this.postRequest('/employee/basic/', this.emp).then(resp =>{
              if (resp){
                this.dialogVisible = false;
                this.initEmps();
              }
            })
          } else {
            this.putRequest('/employee/basic/', this.emp).then(resp =>{
              if (resp){
                this.dialogVisible = false;
                this.initEmps();
              }
            })
          }
        }
      })
    },
    deleteEmp(data){
      this.$confirm('此操作将永久删除['+data.name+']员工, 是否继续?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        this.deleteRequest('/employee/basic/'+data.id).then(resp =>{
          if (resp){
            this.initEmps();
          }
        })
      }).catch(() => {
        this.$message({
          type: 'info',
          message: '已取消删除'
        });
      });
    },
    showEditEmpView(data){
      this.title = '编辑员工信息';
      this.emp = data;
      this.initPositions();
      this.inputDepName = data.department.name;
      this.dialogVisible = true;
    },
    exportData(){
      this.downloadRequest('/employee/basic/export');
    }
  },
  mounted() {
    this.initPositions();
    this.initEmps();
    this.initData();
  }
}
</script>


<style scoped>

.el-form-item .el-radio-group{
  margin-top: 9px;
}

.slide-fade-enter-active {
  transition: all .8s ease;
}
.slide-fade-leave-active {
  transition: all .5s cubic-bezier(1.0, 0.5, 0.8, 1.0);
}
.slide-fade-enter, .slide-fade-leave-to
  /* .slide-fade-leave-active for below version 2.1.8 */ {
  transform: translateX(10px);
  opacity: 0;
}

</style>